草庐IT

JavaScript RegExp : match, 但不捕获

全部标签

ruby - 遍历每个 "match"(Ruby 正则表达式)

好的,我可以在字符串中找到正则表达式匹配项,并进行一些捕获。现在,如果我的字符串有很多匹配项怎么办?假设我的代码找出字符串中括号内的数字。该代码将在类似的字符串中找到数字(5)但是如果字符串是(5)(6)(7)我需要一种方法来遍历这三个元素。我看过教程,但他们似乎只谈论一次性比赛...... 最佳答案 如果我没理解错的话,你可以使用String#scan方法。请参阅文档here. 关于ruby-遍历每个"match"(Ruby正则表达式),我们在StackOverflow上找到一个类似的

ruby-on-rails - ruby 正则表达式错误 : incompatible encoding regexp match (ASCII-8BIT regexp with UTF-8 string)

我遇到了两个错误,都与编码有关并且都相关。我在启动WEBrick时遇到的第一个错误(技术上是警告):/Users/USERNAME/example/config/initializers/bb-ruby.rb:54:warning:invalidUnicodeProperty\P:/\:\-?\P/它所指的行是:/\:\-?\P/,这只是一些正则表达式,最终是这个block的一部分:@@tags['Razzing']=[/\:\-?\P/,'','Razzing',':P',:razzing]然后,我在解析一些字符串时也得到了以下错误(大概是由于同一行)...Encoding::Com

ruby - 在 Ruby gsub block (正则表达式)中使用命名捕获组

我正在尝试在Ruby的block内使用命名捕获组。$1仍然有效,但我想使用我提供的名称来引用它。"foo/(bar)".gsub(/(?\(.*?\))/x)do|match|puts"$1=#{$1}and$my_word=#{$my_word}"end预期:$1=(bar)and$my_word=(bar) 最佳答案 你在找"foo/(bar)".gsub(/(?\(.*?\))/x)do|match|puts"$1=#{$1}and$my_word=#{$~[:my_word]}"end

ruby - 如何从 Capistrano 中的远程命令捕获输出?

我想运行一个远程命令(几个文件夹中的current_revision和HEAD的gitdiff)并捕获输出。我试过运行(“gitdiffrev1rev2--folder|cat”),但该方法似乎总是返回nil(即使我可以在Capistrano输出中看到diff输出)。有什么想法吗?我可以使用不同的管道命令方式或类似方式吗?我不是Unix向导,所以我在这里可能缺少一些微不足道的东西。 最佳答案 也许捕获?“捕获助手将在第一个匹配的服务器上执行给定的命令,并将命令的输出作为字符串返回。”https://github.com/capist

第二季5:配置视频捕获模块(step3:VI模块)

以下内容源于朱有鹏嵌入式课程的学习与整理,如有侵权请告知删除。前言本文将详细介绍博文第二季3:sample_venc.c的整体分析提及的“配置视频捕获模块”。分析方法上,我们首先介绍VI模块相关的宽动态、设备、通道等概念,然后绘制VI模块的函数调用关系图谱,接着讲解具体的代码细节。学习效果上,要把控全局,掌握一些新的概念和对应的数据结构,理解关键操作在哪里设置,将来需要修改的时候能找到地方。一、VI模块的相关概念1、离线/在线模式VI和VPSS的协作模式分为以下2种:VI/VPSS离线模式,是指VI进行时序解析后将图像数据写出到DDR,VPSS从DDR中载入VI采集的数据进行图像处理,是传统H

ruby-on-rails - 开始救援未捕获错误

我正在使用一些包含在begin-rescueblock中的ruby​​代码,但它仍然以某种方式崩溃。代码块如下所示:#Retrievemessagesfromserverdefget_messages@connection.select('INBOX')@connection.uid_search(['ALL']).eachdo|uid|msg=@connection.uid_fetch(uid,'RFC822').first.attr['RFC822']beginprocess_message(msg)add_to_processed_folder(uid)if@processed_

ruby-on-rails - Ruby 2.0.0 字符串#Match ArgumentError : invalid byte sequence in UTF-8

我经常看到这种情况,但还没有想出一个优雅的解决方案。如果用户输入包含无效的字节序列,我需要能够让它不引发异常。例如:#@raw_responsecomesfromuserandcontainsinvalidUTF-8#forexample:@raw_response="\xBF"regex.match(@raw_response)ArgumentError:invalidbytesequenceinUTF-8已经问了很多类似的问题,结果似乎是对字符串进行编码或强制编码。然而,这些都不适合我:regex.match(@raw_response.force_encoding("UTF-8"

ruby - 具有命名捕获组的正则表达式在 Ruby 中获取所有匹配项

我有一个字符串:s="123--abc,123--abc,123--abc"我尝试使用Ruby1.9的新功能“命名组”来获取所有命名组信息:/(?\d*)--(?\s*)/是否有像Python的findall那样返回matchdata集合的API?在这种情况下,我需要返回两个匹配项,因为123和abc重复两次。每个匹配数据都包含每个命名捕获信息的详细信息,因此我可以使用m['number']获取匹配值。 最佳答案 命名捕获只适用于一个匹配结果。Ruby的findall类比是String#scan.您可以使用scan结果作为数组,或将

ruby 正则表达式 : match and get position(s) of

我想匹配一个正则表达式并获取匹配字符串中的位置例如,"AustinTexasDallasTexas".match_with_posn/(Texas)/我想要match_with_posn返回类似:[6,17]其中6和17是单词Texas的两个实例的起始位置。有这样的吗? 最佳答案 使用Ruby1.8.6+,你可以这样做:require'enumerator'#Onlyfor1.8.6,newerversionsshouldnotneedthis.s="AustinTexasDallasTexas"positions=s.enum_f

ruby - 如何在 "case when"中捕获 Errno::ECONNRESET 类?

我的应用程序(Ruby1.9.2)可能会引发不同的异常,包括网络连接中断。我rescueException=>e,然后执行case/when以不同的方式处理它们,但是我的案例中有几个错误直接到else.rescueException=>epe.classcasee.classwhenErrno::ECONNRESETp1whenErrno::ECONNRESET,Errno::ECONNABORTED,Errno::ETIMEDOUTp2elsep3endend打印:Errno::ECONNRESET3 最佳答案 这是因为===运算